package com.itqf.ipmsys.config;



import com.itqf.ipmsys.realm.ShiroRealm;
import org.apache.shiro.authc.credential.HashedCredentialsMatcher;
import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
import org.apache.shiro.web.mgt.WebSecurityManager;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.LinkedHashMap;
import java.util.Map;

/**
 * @author corn
 * @create 2021-09-22 20:26
 * @Description: Shiro配置类
 */
@Configuration
public class ShiroConfig {
    @Bean
    public ShiroFilterFactoryBean shirFilter(WebSecurityManager securityManager) {
        System.out.println("--------ShiroConfiguration.shirFilter()");
        // 添加安全管理器
        ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
        shiroFilterFactoryBean.setSecurityManager(securityManager);
        // 如果不设置默认会自动寻找Web工程根目录下的"/index.jsp"页面
        shiroFilterFactoryBean.setLoginUrl("/");
        // 登录成功后要跳转的链接
        // shiroFilterFactoryBean.setSuccessUrl("/?path=user/main");
        // 添加shiro内置过滤器
        /**
         * anon:表示可以匿名使用。 authc:表示需要认证(登录)才能使用，没有参数
         *
         * roles：参数可以写多个，多个时必须加上引号，并且参数之间用逗号分割，当有多个参数时，
         * 例如admins/user/**=roles["admin,guest"],每个参数通过才算通过，相当于hasAllRoles()方法。
         *
         * perms：参数可以写多个，多个时必须加上引号，并且参数之间用逗号分割，
         * 例如/admins/user/**=perms["user:add:*,user:modify:*"]，
         * 当有多个参数时必须每个参数都通过才通过，想当于isPermitedAll()方法。
         *
         * rest：根据请求的方法，相当于/admins/user/**=perms[user:method]
         * ,其中method为post，get，delete等。
         *
         * port：当请求的url的端口不是8081是跳转到schemal://serverName:8081?queryString,
         * 其中schmal是协议http或https等，serverName是你访问的host,8081是url配置里port的端口，
         * queryString是你访问的url里的？后面的参数。 authcBasic：没有参数表示httpBasic认证
         *
         * ssl:表示安全的url请求，协议为https user:当登入操作时不做检查
         */
        Map<String, String> filterChainDefinitionMap = new LinkedHashMap<String, String>();
        // 静态资源的处理
        filterChainDefinitionMap.put("/js/**", "anon");
        filterChainDefinitionMap.put("/css/**", "anon");
        filterChainDefinitionMap.put("/img/**", "anon");
        filterChainDefinitionMap.put("/fonts/**", "anon");
        filterChainDefinitionMap.put("/plugins/**", "anon");
//		// 请求路径的处理
        //filterChainDefinitionMap.put("/H-PLE/**", "authc");

        // 退出系统的过滤器
        //filterChainDefinitionMap.put("/userInfo/logout", "logout");
        //filterChainDefinitionMap.put("/userInfo/login", "anon");

        // 默认所有资源必须认证才能访问
        //filterChainDefinitionMap.put("/**", "authc");

        // 未授权界面;
        //shiroFilterFactoryBean.setUnauthorizedUrl("/403");
        shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
        return shiroFilterFactoryBean;
    }

    /**
     * 密码处理器
     * @return
     */
    @Bean
    public HashedCredentialsMatcher hashedCredentialsMatcher() {
        HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher();
        hashedCredentialsMatcher.setHashAlgorithmName("md5");// 散列算法:这里使用MD5算法;
        hashedCredentialsMatcher.setHashIterations(6);// 散列的次数（默认一次），比如散列两次，相当于 md5(md5(""));
        return hashedCredentialsMatcher;
    }

    //shiro
    @Bean
    public ShiroRealm myShiroRealm(HashedCredentialsMatcher hashedCredentialsMatcher) {
        ShiroRealm shiroRealm = new ShiroRealm();
        shiroRealm.setCredentialsMatcher(hashedCredentialsMatcher);
        return shiroRealm;
    }

    //secritymanager
    @Bean
    public WebSecurityManager securityManager(ShiroRealm myShiroRealm) {
        DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
        securityManager.setRealm(myShiroRealm);
        return securityManager;
    }


    /**
     * 开启shiro aop注解支持. 使用代理方式;所以需要开启代码支持;
     *
     * @param securityManager
     * @return
     */
    //@Bean
    //public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(WebSecurityManager securityManager) {
    //    AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor = new AuthorizationAttributeSourceAdvisor();
    //    authorizationAttributeSourceAdvisor.setSecurityManager(securityManager);
    //    return authorizationAttributeSourceAdvisor;
    //}

}
